package jzOffer;

import java.util.HashMap;
import java.util.Map;

class Node2 {
    int val;
    Node2 next;
    Node2 random;

    public Node2(int val) {
        this.val = val;
        this.next = null;
        this.random = null;
    }
}
public class Num35 {
    public Node2 copyRandomList(Node2 head) {
        if(head==null) return null;
        Map<Node2, Node2> map=new HashMap<>();
        for(Node2 node = head; node!=null; node=node.next){
            Node2 newNode=new Node2(node.val);
            map.put(node,newNode);
        }
        for(Node2 node = head; node!=null; node=node.next){
            map.get(node).next=map.get(node.next);
            map.get(node).random=map.get(node.random);
        }
        return map.get(head);
    }
}
